<template>
  <div>
    <!-- 搜索页面头部 -->
    <div class="search-header">
      <!-- 后退按钮 -->
      <van-icon name="arrow-left" color="white" size="0.48rem" class="goback" @click="$router.back()"/>
      <!-- 搜索组件 -->
      <van-search placeholder="请输入搜索关键词" background="#007BFF" shape="round" 
      v-fofo 
      v-model.trim="kw" 
      @input="inputFn"
      @search="searchFn"
      />
    </div>
    <!-- 搜索建议列表 -->
    <div class="sugg-list" v-if="kw.length !== 0">
    <div class="sugg-item" v-for="(str,index) in suggessList" 
    :key="index" 
    v-html="lightFn(str,kw)" 
    @click="suggessClickFn(str)"
    >
    </div>
</div>
      <!-- 搜索历史 -->
<div class="search-history" v-else>
    <!-- 标题 -->
    <van-cell title="搜索历史">
        <!-- 使用 right-icon 插槽来自定义右侧图标 -->
        <template #right-icon>
			<van-icon name="delete" class="search-icon" @click="clearFn"/>
        </template>
    </van-cell>

    <!-- 历史列表 -->
    <div class="history-list">
        <span class="history-item" v-for="(str,index) in history" :key="index" @click="historyClickFn(str)">{{str}}</span>
    </div>
</div>
  </div>
</template>

<script>
// 目标1：跳转到搜索结果页面
// 1. 输入框回车 -> 输入框字 -> 搜索结果页
// 2. 点击联想菜单 -> 点击文字 -> 搜索结果页
// 3. 点击历史记录 -> 点击文字 -> 搜索结果页
import {suggesstionAPI} from '@/api/index'
export default {
  data () {
    return {
      kw: '', // 搜索关键字
      timer: null, // 防抖的定时器
      suggessList: [], // 联想建议数据
      history: JSON.parse(localStorage.getItem('his')) || [] // 搜索历史
    }
  },
  methods: {
    // 输入框 - 内容实时改变触发事件方法
    inputFn () {
      clearTimeout(this.timer)
      // 防抖：延时执行逻辑代码,事件再次触发时，清除上一个定时器   
      if (this.kw.length === 0) {
        this.suggessList = []
      } else {
        this.timer = setTimeout(async () => {
        const res = await suggesstionAPI({
          keywords: this.kw
        })
        console.log(res)
        this.suggessList = res.data.data.options
      },500)
      }
    },
    // 专门处理字符串高亮关键字
    lightFn (originStr,target) {
     try {
       // originStr: 原来字符串
      // target: 关键字
      // 字符串.replace() 
      // 例如："好同志,都是招募来的",关键字是:'好'
      // 返回值：替换后的完整字符串

      // 如果你想要使用变量,作为正则的匹配条件,不能用语法糖简化写法
      const reg = new RegExp(target,'ig') // i忽略大小写,g全局都匹配

      // 替换后的值不能用target
      // 例如：输入框里 java,匹配回来的联想菜单Java,JAVA,jAVA,都被你replace换成输入框target值java
      return originStr.replace(reg,(match) => {
        return `<span style="color:red">${match}</span>`
      })
     } catch(e) {
      console.log(e.message)
     }
      
    },
    moveFn (theKw) { // 路由跳转传参
      // 坑：路由跳转,在watch之前执行,所以我们要让路由跳转,来一个定时器吧包裹,让跳转最后执行
      setTimeout(() => {
        this.$router.push({
        path: `/search_result/${theKw}`
      })
      },0)
    },
    // 输入框事件
    searchFn () {
      // 搜索关键字 - 保存到数组里
      this.history.push(this.kw)
      this.moveFn(this.kw)
    },
    // 联想菜单的点击事件
    suggessClickFn (str) {
     // 搜索关键字 - 保存到数组里
     this.history.push(str)
     this.moveFn(str)
    },
    // 历史菜单点击事件
    historyClickFn (str){
     this.moveFn(str)
    },
    // 清除历史记录
    clearFn () {
      this.history = []
    }
  },
  // watch侦听器使用
  watch: {
    history: {
      // 历史记录数组的改变
      deep: true,
      handler () {
        // 立刻覆盖式的保存到本地
        // ES6新增了2中引用类型(以前 Array,Object),(新增:set Map)
        // Set: 无序不重复的value集合体(无下角标)
        // 特点：传入的数组类型,如果有重复元素,会自动清理掉重复元素,返回无重复的Set对象
        // 注意：如果值是对象比较的是对象内存地址
        const theSet = new Set(this.history)
        // Set类型对象 -> 转回 -> Array数组类型
        const arr = Array.from(theSet)
        localStorage.setItem('his',JSON.stringify(arr))
      }
    }
  }
}
</script>

<style scoped lang="less">
.search-header {
  height: 46px;
  display: flex;
  align-items: center;
  background-color: #007bff;
  overflow: hidden;
  /*后退按钮*/
  .goback {
    padding-left: 14px;
  }
  /*搜索组件*/
  .van-search {
    flex: 1;
  }
}

/*搜索建议列表样式 */
.sugg-list {
  .sugg-item {
    padding: 0 15px;
    border-bottom: 1px solid #f8f8f8;
    font-size: 14px;
    line-height: 50px;
    // 实现省略号的三行代码
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }
}

/**搜索历史 */
.search-icon {
  font-size: 16px;
  line-height: inherit;
}

.history-list {
  padding: 0 10px;
  .history-item {
    display: inline-block;
    font-size: 12px;
    padding: 8px 14px;
    background-color: #efefef;
    margin: 10px 8px 0px 8px;
    border-radius: 10px;
  }
}
</style>
